home *** CD-ROM | disk | FTP | other *** search
/ AmigActive 10 / AACD 10.iso / AACD / Online / SpeakFreely / src / gsm / tst / lin2cod.c < prev    next >
C/C++ Source or Header  |  2000-05-18  |  2KB  |  103 lines

  1. /*
  2.  * Copyright 1992 by Jutta Degener and Carsten Bormann, Technische
  3.  * Universitaet Berlin.  See the accompanying file "COPYRIGHT" for
  4.  * details.  THERE IS ABSOLUTELY NO WARRANTY FOR THIS SOFTWARE.
  5.  */
  6.  
  7. /*$Header: /home/kbs/jutta/src/gsm/gsm-1.0/tst/RCS/lin2cod.c,v 1.1 1992/10/28 00:32:06 jutta Exp $*/
  8.  
  9. #include <stdio.h>
  10.  
  11. #include "gsm.h"
  12. #include "proto.h"
  13.  
  14. char  * pname;
  15.  
  16. int    debug      = 0;
  17. int    verbosity  = 0;
  18. int    fast       = 0;
  19. int    error      = 0;
  20.  
  21. usage P0()
  22. {
  23.     fprintf(stderr, "Usage: %s [-vF] [files...]\n", pname);
  24.     exit(1);
  25. }
  26.  
  27. void process P2((f, filename), FILE * f, char * filename)
  28. {
  29.     gsm_frame    buf;
  30.     short        source[160];
  31.     int        cc;
  32.     gsm        r;
  33.  
  34.     if (!(r = gsm_create())) {
  35.         perror("gsm_create");
  36.         error = 1;
  37.         return ;
  38.     }
  39.     gsm_option(r, GSM_OPT_VERBOSE, &verbosity);
  40.     gsm_option(r, GSM_OPT_FAST,    &fast);
  41.     for (;;) {
  42.  
  43.         if ((cc = fread((char *)source, 1, sizeof(source), f)) == 0) {
  44.             gsm_destroy(r);
  45. #ifdef    COUNT_OVERFLOW
  46.             dump_overflow(stderr);
  47. #endif
  48.             return;
  49.         }
  50.  
  51.         if (cc != sizeof(source)) {
  52.             error = 1;
  53.             perror(filename);
  54.             fprintf(stderr, "%s: cannot read input from %s\n",
  55.                 pname, filename);
  56.             gsm_destroy(r);
  57.             return;
  58.         }
  59.  
  60.         gsm_encode(r, source, buf);
  61.         gsm_explode(r, buf, source);    /* 76 shorts */
  62.         if (write(1, source, sizeof(*source) * 76)
  63.             != sizeof(*source) * 76) {
  64.  
  65.             perror("write");
  66.             error = 1;
  67.             gsm_destroy(r);
  68.             return;
  69.         }
  70.     }
  71. }
  72.  
  73. main P2((ac, av), int ac, char ** av)
  74. {
  75.     int         opt;
  76.     extern char   * optarg;
  77.     extern int    optind;
  78.  
  79.     FILE        * f;
  80.  
  81.     if (!(pname = av[0])) pname = "inp2cod";
  82.  
  83.     while ((opt = getopt(ac, av, "vF")) != EOF) switch (opt) {
  84.     case 'v': verbosity++;    break;
  85.     case 'F': fast++;         break;
  86.     default:  usage();
  87.     }
  88.  
  89.     ac -= optind;
  90.     av += optind;
  91.  
  92.     if (!ac) process(stdin, "*stdin*");
  93.     else for (; *av; av++) {
  94.         if (!(f = fopen(*av, "r"))) perror(*av);
  95.         else {
  96.             process(f, *av);
  97.             fclose(f);
  98.         }
  99.     }
  100.  
  101.     exit(error);
  102. }
  103.